Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Iterative partitioning #134

Open
wants to merge 40 commits into
base: master
Choose a base branch
from
Open

Iterative partitioning #134

wants to merge 40 commits into from

Conversation

conp-solutions
Copy link
Owner

No description provided.

@conp-solutions conp-solutions force-pushed the iterative-partitioning branch 2 times, most recently from 0d507d3 to f199d2d Compare April 25, 2023 21:04
... to speedup the build, and avoid unnecessary rebuilds.

Signed-off-by: Norbert Manthey <[email protected]>
We want to build different MergeSat-based Dockerfiles. Hence,
this change introduce configurability. This way, multiple
docker images can be build from the same Dockerfile.

Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Basic type to maintain a partition tree.

Signed-off-by: Norbert Manthey <[email protected]>
Implement helper methods to be able to work with the
partition tree.

Signed-off-by: Norbert Manthey <[email protected]>
Support starting partitioning after some syncs.

Signed-off-by: Norbert Manthey <[email protected]>
Implement the first stubs to support partitioning the search space next.

Signed-off-by: Norbert Manthey <[email protected]>
Add a separate method to handle UNSAT cases when a solver
returns from solving a partition.

Note: the actual relevant code is not added yet, this
change only moves the exception into a better place for
future iteration.

Signed-off-by: Norbert Manthey <[email protected]>
... so that controlling their allocation is properly
jailed.

Signed-off-by: Norbert Manthey <[email protected]>
... based on the position of each node on the path to the
root among its siblings.

The signature can be used to print traces during debugging,
or to print the actual partition tree.

Signed-off-by: Norbert Manthey <[email protected]>
This method allows to load the assumptions for a solver when
it is asked to solver a partition of the search space.

Signed-off-by: Norbert Manthey <[email protected]>
Furthermore, wrap assigning a node to a thread in a separate
method to have a single location to control this change.

Signed-off-by: Norbert Manthey <[email protected]>
This change adds the work in progress state for solving formulas
in parallel, while maintaining and assigning partitions to threads.

Note: there is no option to enable or disable this functionality
yet. Furthermore, the solver might be very verbose at this point.

Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
@conp-solutions conp-solutions force-pushed the iterative-partitioning branch 2 times, most recently from 8c6548d to 94d619f Compare April 28, 2023 18:32
Note: this commit should not be required in case all
other commits get formatting applied.

Signed-off-by: Norbert Manthey <[email protected]>
... so that we do not have any left-overs later on.

Signed-off-by: Norbert Manthey <[email protected]>
... because otherwise there should not be a global conflict.

Signed-off-by: Norbert Manthey <[email protected]>
When a partition is solved, the solver enters sync with l_False.
However, we want to be able to assign this status back to
l_Undef, as we might assign a new partition to the solver.

Signed-off-by: Norbert Manthey <[email protected]>
The initial code did not iterate in the tree. Furthermore, the
status of the solver, as well as the conflict of the involved
solver need to be reset once we collect an unsatisfiable node.

Note: this change could also be merged in the previous commit
of this function.

Signed-off-by: Norbert Manthey <[email protected]>
When a solver finds a conflict, we need to process it immediately.
Otherwise, the l_False status would be propagated back to search,
which then will terminate with UNSAT; leading to a wrong locking
order and a deadlock.

Signed-off-by: Norbert Manthey <[email protected]>
... instead of waiting for 1000 syncs by default.

Signed-off-by: Norbert Manthey <[email protected]>
... as partitioning then uses assumptions, and the involved
variables might have been eliminated by the time.

Signed-off-by: Norbert Manthey <[email protected]>
When we find UNSAT during sync, e.g. by receiving clauses, make
sure this status is propagated to the thread status as well, as
this is used to then terminate search with the proper status as
well.

Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
Signed-off-by: Norbert Manthey <[email protected]>
@conp-solutions conp-solutions force-pushed the iterative-partitioning branch from 94d619f to 9534f3d Compare April 28, 2023 19:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant